next up previous contents index
Next: Objects Up: Types Previous: Pointers

Procedural types

Free Pascal has support for procedural types, although it differs a little from the Turbo Pascal implementation of them. The type declaration remains the same, as can be seen in the following syntax diagram:


Procedural types

syntdiag1899

syntdiag1903

syntdiag1907

syntdiag1911

For a description of formal parameter lists, see chapter (gif).

The two following examples are valid type declarations:
listing1847

One can assign the following values to a procedural type variable:

  1. Nil, for both normal procedure pointers and method pointers.
  2. A variable reference of a procedural type, i.e. another variable of the same type.
  3. A global procedure or function address, with matching function or procedure header and calling convention.
  4. A method address.

Given these declarations, the following assignments are valid:
listing1852
From this example, the difference with Turbo Pascal is clear: In Turbo Pascal it isn't necessary to use the address operator (@) when assigning a procedural type variable, whereas in Free Pascal it is required (unless you use the -So switch, in which case you can drop the address operator.)

Remark that the modifiers concerning the calling conventions (cdecl, pascal, stdcall and popstack stick to the declaration; i.e. the following code would give an error:
listing1860
Because the TOneArgCcall type is a procedure that uses the cdecl calling convention.

At the moment, the method procedural pointers (i.e. pointers that point to methods of objects, distinguished by the of object keywords in the declaration) are still in an experimental stage.


next up previous contents index
Next: Objects Up: Types Previous: Pointers

Michael Van Canneyt
Fri Sep 25 09:15:40 MEST 1998